| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- import { NextApiHandler, NextApiRequest, NextApiResponse } from 'next'
- import NextAuth from 'next-auth'
- import Providers from 'next-auth/providers'
-
- export default function Auth(
- req: NextApiRequest,
- res: NextApiResponse
- ): ReturnType<NextApiHandler> {
- return NextAuth(req, res, {
- providers: [
- Providers.GitHub({
- clientId: process.env.GITHUB_ID,
- clientSecret: process.env.GITHUB_SECRET,
- scope: 'read:user',
- }),
- ],
- callbacks: {
- async redirect(url, baseUrl) {
- return url.startsWith(baseUrl) ? url : baseUrl
- },
- async signIn(user, account, profile: any) {
- const canLogin = await isSponsoringMe(profile?.login)
-
- if (canLogin) {
- return canLogin
- } else {
- return '/sponsorware'
- }
- },
- },
- })
- }
-
- const whitelist = ['steveruizok']
-
- async function isSponsoringMe(login: string) {
- if (whitelist.includes(login)) return true
-
- const res = await fetch('https://api.github.com/graphql', {
- method: 'POST',
- headers: {
- 'Content-Type': 'application/json',
- Authorization: 'bearer ' + process.env.GITHUB_API_SECRET,
- },
- body: JSON.stringify({
- query: `
- query {
- user(login: "steveruizok") {
- isSponsoredBy(accountLogin: "${login}")
- }
- }
- `,
- }),
- }).then((res) => res.json())
-
- return res?.data?.user?.isSponsoredBy
- }
|